草庐IT

mysql - 多对多关系SQL查询

全部标签

ruby-on-rails - 弃用警告 : Dangerous query method (method whose arguments are used as raw SQL) called with non-attribute argument(s)

我将我的Rails5.1.4应用更新到了5.2.0。我的一个模型中有以下范围:scope:by_category,lambda{|category_slug|category_ids=Category.find_by(slug:category_slug)&.subtree_idswhere(category_id:category_ids)}由于该范围,Rails返回以下错误:DEPRECATIONWARNING:Dangerousquerymethod(methodwhoseargumentsareusedasrawSQL)calledwithnon-attributeargume

ruby - 使用 :sql 模式格式时如何使 rake db :migrate generate schema. rb

如果在config/application.rb中使用这个选项:config.active_record.schema_format=:sql然后当你这样做时:rakedb:migrate它只转储db/structure.sql。我知道它没有使用db/schema.rb因为它使用的是:sql选项,但是你如何制作rakedb:migrate还生成db/schema.rb吗?我们需要它,因为RubyMine4.5和IntelliJIDea11使用db/schema.rb来自动完成列。 最佳答案 要生成/更新db/schema.rb,即使

ruby-on-rails - Heroku:PG::错误:错误:关系的权限被拒绝

每次我尝试将某些内容保存到数据库中时,都会收到此错误消息。我看到Heroku为前10.000条记录提供免费的PostgreSQL数据库,超过10.000条记录需要支付数据库费用。现在,我的数据库中大约有60.000条记录。如何修复该错误/升级数据库?提前致谢 最佳答案 您需要使用PGBackups附加组件来备份您的数据库,然后从您的开发/基本计划迁移到生产级(付费)计划。它的缺点:提供新的生产级HerokuPostgresql计划将您的应用置于维护模式以防止新的更新获取备份恢复到升级后的数据库将新数据库提升为主重新激活您的应用htt

ruby - 为什么要使用 SQL 构建器? Arel 诉 Sequel 诉 T-SQL

我正在尝试了解通过面向对象的构建器DSL构建SQL与参数化原始SQL字符串相比的优势。在以三种方式研究/实现相同的查询之后,我注意到原始SQL是迄今为止最容易阅读的。这就引出了一个问题,“为什么要跳过一个箍?”为什么不直接声明和使用原始SQL?这是我想出的:首先,我猜它使SQL更具可移植性,因为它可以被任何带有适配器的数据库使用。我猜这是大人物,对吧?尽管如此,难道大多数T-SQL不是大多数数据库都能理解的吗?其次,它提供了一个可以重复使用的查询对象——作为其他查询、命名范围链接等的基础。通过构建SQL而不是声明SQL,您实现的主要投资返回是什么?definstances_of_sql

ruby-on-rails - ActiveRecord 查询 : where a field is not true

我想查找某个字段不正确的所有记录。用于此的有效AR语法是:Dog.where(:stray=>[false,nil])是否有更简洁的方式来查询“nottrue”?到处都必须迎合这种mysql的细微差别,这真的很糟糕。 最佳答案 命名作用域怎么样?scope:not_stray,where("strayISNULLORstray=false")然后使用:Dog.not_stray 关于ruby-on-rails-ActiveRecord查询:whereafieldisnottrue,我们在

sql - Ruby Rails - 使用 created_at 列制作表格

Rubyonrails有t.timestamps方法创建两列,created_at和updated_at。我怎样才能只创建created_at列?这行得通classCreateLinesSources这两个我都想工作但是都失败了classCreateLinesSources和classCreateLinesSources 最佳答案 t.datetime:created_at,null:false就像任何其他专栏一样。由于列名,Rails仍会负责魔术更新。 关于sql-RubyRails-

ruby-on-rails - Ruby on Rails 多态关系的优点和缺点

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭9年前。Improvethisquestion您知道RubyonRails多态关系的优点和缺点。

ruby - 如何优化 ActiveRecord find_in_batches 查询?

我正在使用Rails4.0.0和Ruby2.0.0。我的Post(如在博客文章中)模型与用户相关联,该用户具有用户的user_name、first_name、last_name的组合。我想迁移数据,以便通过外键(即用户ID)将帖子关联到用户。我在posts表中有大约1100万条记录。我在Linux服务器上使用rake任务运行以下代码来迁移数据。然而,我的任务一直被服务器“杀死”,大概是由于rake任务,特别是下面的代码,消耗了太多内存。我发现将batch_size降低到20并将sleep(10)增加到sleep(60)允许任务运行更长的时间,在不被杀死的情况下总共更新更多的记录,但需要

ruby - 为什么我会有很多关系?

我刚刚遇到了一个关于关系和数据库的有趣情况。我正在编写一个ruby​​应用程序,我正在为我的数据库使用postgresql。我有一个父对象“用户”和一个相关对象“事物”,用户可以在其中拥有一个或多个事物。使用单独的表与仅将数据嵌入父表的字段中有什么优势?来自ActiveRecord的示例:使用相关表:defchangecreate_table:usersdo|i|i.text:nameendcreate_table:thingiesdo|i|i.integer:thingiei.text:discriptionendendclassUser使用嵌入式数据结构(多维数组)方法:defch

ruby-on-rails - 如何在 Rails ActiveRecord 中正确分配 has_many/belongs_to 关系?

我有一个带有文章和作者模型的Rails应用程序。如果我有一个作者和一个帖子,并且想表明作者应该是文章的所有者,或者文章属于作者,那么这样做的最佳做法是什么?特别是:如果我设置了会有什么不同my_article.author_id=author_one.id或者如果我这样做author_one使用的关联是作者有_多篇文章文章属于作者另外,如果出现类似问题,最好的查找方式是什么? 最佳答案 以下3个没有区别:my_article.author_id=author_one.idmy_article.save#sameasmy_articl